

# **STORM** SoC – System on Chip by Stephan Nolting

# **Datasheet and Implementation Guide**



## **Proprietary Notice**

The **STORM CORE** Processor System and the **STORM SoC** were created by Stephan Nolting. Contact: <a href="mailto:stnolting@googlemail.com">stnolting@googlemail.com</a>, <a href="mailto:zero">zero</a> gravity@opencores.org

The most recent versions of them can be found at

STORM Core: <a href="http://www.opencores.com/project,storm\_core">http://www.opencores.com/project,storm\_core</a>
STORM SoC: <a href="http://www.opencores.com/project,storm\_soc">http://www.opencores.com/project,storm\_soc</a>

#### Table of content

#### 1. Introduction

#### 2. STORM SoC Basic

- **2.1** Features
- 2.2 Port Description

## 3. System Setup

- **3.1** Adding / Removing Components
- 3.2 Changing Memory Size
- **3.3** Software Setup
- **3.4** Using the Bootloader

## 4. System Components

- **4.1** STORM Core Processor
- **4.2** Internal SRAM Memory
- **4.3** Boot ROM Memory
- **4.4** IO Controller
- **4.5** Seven Segment Controller
- **4.6** Timer
- **4.7** Vector Interrupt Controller
- **4.8** Mini UART
- **4.9** SPI Controller
- **4.10** I<sup>2</sup>C Controller
- **4.11** PS-2 Interface
- **4.12** External Memory Controller
- **4.13** Reset Protector
- **4.14** System PLL
- **4.15** PWM Controller

#### 5. Source Files

- **5.1** Hardware Source Files
- **5.2** Software Source Files

## 6. System Address Map

## 7. Interrupt Channels

#### 1. Introduction

The STORM SoC (System on Chip) is a complete microcontroller system, build around the STORM Core processor. It is completely FPGA and evaluation board – manufacturer independent. Due to it's Wishbone bus system, it can easily be expanded with a large variety of open-source hardware components like memory controller, different communication interfaces and special processing modules.

#### 2. STORM SoC Basic

This project already includes a library of basic system components, which can easily be added or removed from an example system configuration – the STORM\_SoC\_basic. It is intended to serve as initial platform for a user-specified system designs.

IO driver and WinARM compatible makefiles are included within this project. A pre-installed console bootloader can be used for easy program downloading and debugging.

Top entity of the basic STORM SoC configuration: storm\_soc\trunk\basic\_system\rtl\STORM\_SoC\_basic.vhd



>> STORM SoC Basic configuration <<

Note: For a minimum system configuration, which is still able to run the pre-installed bootloader, the shaded modules are mandatory.

#### 2.1 Features of the Basic STORM SoC Configuration

- ✓ Based on the STORM Core Processor System (ARM7 native)
- ✓ 1kb D-cache and 1kb I-cache (both are full-associative)
- ✓ 32-bit Wishbone bus system (pipelined)
- ✓ Clock distribution system (PLL)
- Reset protector
- ✓ WinARM compatible makefiles
- ✓ Pre-defined driver libraries and example programs (C files)
- ✓ Internal 32 kb RAM for program code and data
- ✓ Internal 8 kb ROM with pre-installed bootloader
- ✓ 32-bit system timer
- ✓ Vectorized interrupt controller (LPC compatible)
- ✓ 8 general purpose input pins
- ✓ 8 general purpose output pins
- ✓ Simple mini UART (9600-8-N-1)
- ✓ SPI controller providing 3 ports (3/3/2) chip select lines each)
- ✓ I<sup>2</sup>C controller (boot from I<sup>2</sup>C EEPROM supported by processor)
- ✓ 8 independent PWM outputs

## 2.2 Port Description

This chapter describes the interface of the basic system configuration (top entity).

The type of all signals is std\_logic / std\_logic\_vector. The corresponding signal width is noted in 'bit'. Signal suffix:  $I \rightarrow FPGA$  input pin/port;  $O \rightarrow FPGA$  output pin/port;  $IO \rightarrow FPGA$  bidirectional pin/port

## **System interface:**

| Signal name   | Bit | Function                                                                                                                                                                                                             |  |  |  |
|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| CLK_I         | 1   | System clock input (50MHz suggested),<br>all internal system trigger on the rising edge of this signal,<br>connected to SYSCON_CLK                                                                                   |  |  |  |
| RST_I         | 1   | System reset input (synchronous, low active), this pin is connected to a reset protection circuit – only activating this pin for at least 1 second will generate a valid internal reset, connected to SYSCON RST     |  |  |  |
| UARTO_RXD_I   | 1   | System console terminal data receiver input, fixed interface properties: 9600-8-N-1, connected to GP_UART_0                                                                                                          |  |  |  |
| UARTO_TXD_O   | 1   | System console terminal data transmitter output, fixed interface properties: 9600-8-N-1, connected to GP_UART_0                                                                                                      |  |  |  |
| START_I       | 1   | Start application button (low active!), activating this pin will skip the bootloader and immediately start the application from RAM, mapped to IN(0) of the processor's own system IO port                           |  |  |  |
| BOOT_CONFIG_I | 4   | Power-on boot configuration, "0000" - start bootloader console "0001" - boot from RAM "0010" - boot from I <sup>2</sup> C EEPROM (always from address 0xA0), mapped to IN(4:1) of the processor's own system IO port |  |  |  |
| LED_BAR_O     | 8   | System status output (connect to 8xLEDs), mapped to OUT(7:0) of the processors own system IO port                                                                                                                    |  |  |  |

## **General purpose ports (GP\_IO):**

| Signal name | Bit | Function                                                                                 |  |
|-------------|-----|------------------------------------------------------------------------------------------|--|
| GP_INPUT_I  | 8   | General purpose inputs, mapped to IN(7:0) of GP_IO_CONTROLLER_0, IN(31:8) are set to '0' |  |
| GP_OUTPUT_O |     | General purpose outputs, mapped to OUT(7:0) of GP_IO_CONTROLLER_0                        |  |

## **Inter Integrated-Circuit Bus (I<sup>2</sup>C):**

| Signal name | Bit | Function                                   |  |
|-------------|-----|--------------------------------------------|--|
| I2C_SCL_IO  | 1   | I2C_CONTROLLER_0 serial clock input/output |  |
| I2C_SDA_IO  | 1   | I2C_CONTROLLER_0 data clock input/output   |  |

## **Serial Peripheral Interface (SPI):**

The interface of the SPI controller is split up into three ports allowing to create different bus subsets. For example when accessing internal chip select 3, SPI port 1 is used and CS(0) of SPI port 1 is active (low).

| Signal name   | Bit | Port # | Function                                                                                  |
|---------------|-----|--------|-------------------------------------------------------------------------------------------|
| SPI_PO_CLK_O  | 1   | Port 0 | SPI_CONTROLLER_0 port_0 serial clock output                                               |
| SPI_PO_MISO_I | 1   |        | SPI_CONTROLLER_0 port_0 serial data input, only selected when a CS of this port is active |
| SPI_PO_MOSI_O | 1   |        | SPI_CONTROLLER_0 port_0 serial data output                                                |
| SPI_PO_CS_O   | 3   |        | Port_0 chip select lines (low active),<br>mapped to SS(2:0) of SPI_CONTROLLER_0           |
| SPI_P1_CLK_O  | 1   | Port 1 | SPI_CONTROLLER_0 port_1 serial clock output                                               |
| SPI_P1_MISO_I | 1   |        | SPI_CONTROLLER_0 port_1 serial data input, only selected when a CS of this port is active |
| SPI_P1_MOSI_O | 1   |        | SPI_CONTROLLER_0 port_1 serial data output                                                |
| SPI_P1_CS_O   | 3   |        | Port_1 chip select lines (low active),<br>mapped to SS(5:3) of SPI_CONTROLLER_0           |
| SPI_P2_CLK_O  | 1   | Port 2 | SPI_CONTROLLER_0 port_2 serial clock output                                               |
| SPI_P2_MISO_I | 1   |        | SPI_CONTROLLER_0 port_2 serial data input, only selected when a CS of this port is active |
| SPI_P2_MOSI_O | 1   |        | SPI_CONTROLLER_0 port_2 serial data output                                                |
| SPI_P2_CS_O   | 2   |        | Port_2 chip select lines (low active),<br>mapped to SS(7:6) of SPI_CONTROLLER_0           |

## **Pulse-Width-Modulation (PWM) Port:**

| Signal name | Bit | Function                                              |  |
|-------------|-----|-------------------------------------------------------|--|
| PWM0_PORT_O | 8   | PWM_CONTROLLER_0 pulse-width-modulated output signals |  |

#### 3. System Setup

This chapter explains step-by-step the setup of the STORM System on Chip. Altera Quartus II © will be used as FPGA design tool.

For other synthesis tools (like Xilinx IDE ©) the basic setup flow is nearly the same.

Terminal v1.9b (copyright by Br@y++) will be used as com port terminal program. Of course, any other terminal program providing a file transfer option can be used as well.

#### **Basic Setup Flow**

- 1) Start Altera Quartus II and create a new project.
- 2) Configure the device settings corresponding to your target FPGA.
- 3) Add all core and system module HDL files to the project (a list of all hardware source files can be found in chapter 5.1). Also, add a PLL (configuration described in the PLL chapter) with the Megawizzard tool to the design.
- 4) Declare the 'STORM\_SoC\_basic.vhd' as the design's top entity.
- 5) Add / remove system components to fit the design to your application.

  → see chapter 3.1
- 6) Configure the system settings (internal SRAM size, external reset level, clock frequency, ...). → see chapter 3.2
- 7) Start the synthesis of the design.
- 8) Open the pin assignment editor and assign FPGA pins to the interface ports.
- 9) Compile your design.
- 10) Connect your FPGA evaluation board to the computer and download the configuration bit stream.
- 11) Connect the UART port of the STORM SoC via an RS232 interface to your computer and open the terminal program. Select the correct COM port and set the interface properties (baud rate = 9600, 8 data bits, 1 stop bit, no parity bit).
  - $\rightarrow$  see chapter 3.4
- 12) Press the configured reset button of the STORM SoC for at least 1 second. After wards, the bootloader console will show up in the terminal window.
- 13) Press (and send) '1' ("program core RAM with program file"). Then, transmit the application code ('storm\_program.bin' file) in byte stream mode.

  → see chapter 3.3
- 14) The application program will start automatically after the download has finished.

#### 3.1 Adding / Removing Components

You can expand the basic STORM SoC configuration to fit your specific application. In this chapter I will show you how to add additional components to the design. As an example, the pulse-width-modulation controller will be instantiated.

To remove components from the design, precede with this tutorial – just delete all the new entries and signals, which are created here.

#### 3.1.1 Adding the module to the components list

First of all, you have to make sure the component is already listed within the components list of the STORM SoC top entity (for the case of the basic configuration, the module is already listed). Don't forget to add the module's source file(s) to the project sources as well.

```
component PWM_CTRL

port (

-- Wishbone Bus --

WB_CLK I : in STD_LOGIC; -- memory master clock

WB_RST_I : in STD_LOGIC VECTOR(02 downto 0); -- cycle identifier

WB_TGC_I : in STD_LOGIC_VECTOR(06 downto 0); -- cycle tag

WB_ADR_I : in STD_LOGIC; -- address input

WB_DATA_I : in STD_LOGIC_VECTOR(31 downto 0); -- write data

WB_DATA_O : out STD_LOGIC_VECTOR(31 downto 0); -- read data

WB_SEL_I : in STD_LOGIC_VECTOR(31 downto 0); -- data quantity

WB_WE_I : in STD_LOGIC; -- write enable

WB_STB_I : in STD_LOGIC; -- valid cycle

WB_ACK_O : out STD_LOGIC; -- acknowledge

WB_HALT_O : out STD_LOGIC; -- throttle master

WB_ERR_O : out STD_LOGIC; -- abnormal termination

-- PWM Port --

PWM_O : out STD_LOGIC_VECTOR(07 downto 0)

);
end component;
```

<< PWM Controller component declaration in system component list >>

#### 3.1.2 Adding the interconnection signals, IO ports and module addresses

Declare 5 new signals (type std\_logic / std\_logic\_vector) for the module ↔ system bus interface. Even if most of the bus signals are shared within the system (see interface signals of the STORM Core processor), at least five signals must be unique for each bus-connected module.

| Signal name Bit  |    | <u>Function</u>                         |
|------------------|----|-----------------------------------------|
| PWM_CTRL0_DATA_O | 32 | Module data output (for read access)    |
| PWM_CTRLO_STB_I  | 1  | Module select input                     |
| PWM_CTRLO_ACK_O  | 1  | Module acknowledge output               |
| PWM_CTRL0_HALT_O | 1  | Module bus halt request                 |
| PWM_CTRL0_ERR_O  | 1  | Module bus transaction (abnormal) abort |

Note: The 'I' / 'O' suffix refers to the module. For example PWM\_CTRL0\_DATA\_O is a signal driven by the module (PWM controller).

```
-- PWM Controller 0 --
signal PWM_CTRL0_DATA_O : STD_LOGIC_VECTOR(31 downto 0);
signal PWM_CTRL0_STB_I : STD_LOGIC;
signal PWM_CTRL0_ACK_O : STD_LOGIC;
signal PWM_CTRL0_HALT_O : STD_LOGIC;
signal PWM_CTRL0_ERR_O : STD_LOGIC;
```

<< Interconnection signals module ↔ bus system declaration >>

Since the component provides IO ports ("real world peripherals"  $\rightarrow$  PWM outputs), you need to define an interface bus within the entity's port list.

```
-- PWM Port 0 --
PWM0_PORT_O : out STD_LOGIC_VECTOR(07 downto 0);
```

<< Definition of the module's specific IO interface >>

Furthermore, you need to configure the device address and IO size.

Add two new constants to the address map. The PWM\_CTRL0\_BASE\_C constant declares the base address of the module. PWM\_CTRL0\_SIZE\_C declares the size of the occupied IO space of the module in bytes. The PWM controller provides 2 internal registers (each 32 bit wide), which can be accessed via the bus system. So the needed IO address space is 2\*32/8 = 8 byte.

You have to make sure, the base address as well as the occupied IO space is NOT used by any other component. Also, I recommend to use an address within the dedicated IO area.

```
constant PWM_CTRL0_BASE_C : STD_LOGIC_VECTOR(31 downto 0) := x"FFFF0070";
constant PWM_CTRL0_SIZE_C : natural := 2*4; -- byte
```

<< Definition of the module's specific IO interface >>

#### 3.1.3 Adding the unique module signals to the Wishbone fabric

The 5 unique module signals from the previous tutorial part must be included in the Wishbone fabric. This fabric consists of five signal terminals – one for each unique signal.

Add a new address-comparator for the "Valid Transfer Signal Terminal":

<< New entry of STB terminal >>

Insert new entries for the "Read-Back Data Selector Terminal", the "Acknowledge Terminal", the "Abnormal Termination Terminal" and the "Halt Terminal" corresponding to the address-location of your new module (→ canonical):

```
I2CO_CTRL_DATA_O when (I2CO_CTRL_STB_I = '1') else

PWM_CTRLO_DATA_O when (PWM_CTRLO_STB_I = '1') else

VIC_DATA_O when (VIC_STB_I = '1') else
```

<< Inserting the component's read-data bus into the "Read-Back Data Selector Terminal" >>>

```
I2CO_CTRL_ACK_O or
PWM_CTRLO_ACK_O or
VIC_ACK_O or
```

<< Inserting the component's acknowledge signal into the "Acknowledge Terminal" >>

```
I2CO_CTRL_ERR_O or
PWM_CTRLO_ERR_O or
VIC_ERR_O or
```

<< Inserting the component's error signal into the "Abnormal Termination Terminal" >>

```
I2CO_CTRL_HALT_O or

PWM_CTRLO_HALT_O or

VIC_HALT_O or

...
```

<< Inserting the component's halt signal into the "Halt Terminal" >>>

#### 3.1.4 Instantiating the new module

Finally, it is time to instantiate the new component and connect it to the rest of the system.

The PWM controller contains two 32-bit register, which are accessible via the bus system, so it needs a one-bit signal to determine which register is accessed. Since each register is accessible with one specific 32-bit address and both register are 32 bit wide, the address must be on word boundary  $\rightarrow$  connect bit 2 of the system's address bus to the single address input signal.

Even when using components with 8 bit register / data width, you have to map the registers to a complete 32-bit address on word boundary (bis 0 and 1 of the system address bus CORE\_WB\_ADR\_O are always zero). This also implicates the CORE\_WB\_SEL\_O signal (4 bits wide) is always "1111".

```
PWM_CONTROLLER_0: PWM_CTRL

port map (

-- Wishbone Bus --

WB_CLK_I => MAIN_CLK, -- memory master clock

WB_RST_I => MAIN_RST, -- high active sync reset

WB_CTI_I => CORE_WB_CTI_O, -- cycle identifier

WB_TGC I => CORE_WB_TGC O, -- cycle tag

WB_ADR_I => CORE_WB_ADR_O(2), -- address input

WB_DATA_I => CORE_WB_DATA_O, -- write data

WB_DATA_O => PWM_CTRIO_DATA_O, -- read data

WB_SEL_I => CORE_WB_SEL_O, -- data quantity

WB_WE_I => CORE_WB_WCO, -- write enable

WB_STB_I => PWM_CTRIO_STB_I, -- valid cycle

WB_ACK_O => PWM_CTRIO_ACK_O, -- acknowledge

WB_HALT_O => PWM_CTRIO_ACK_O, -- acknowledge

WB_HALT_O => PWM_CTRIO_BRR_O, -- throttle master

WB_ERR_O => PWM_CTRIO_ERR_O, -- abnormal termination

-- PWM_PORT_--

PWM_O => PWMO_PORT_O
```

<< Instantiation and signal connection for the new PWM controller >>

Even if a new component does not feature a halt request signal or an error signal, bus connection signals should be declared and implemented as well ( $\rightarrow$  canonical). Assign a '0' to these unconnected signals then.

```
-- Halt / Error --
I2CO_CTRL_HALT_O <= '0'; -- no throttle -> full speed
I2CO_CTRL_ERR_O <= '0'; -- nothing can go wrong - never ever!
```

<< Signal termination example for unsupported HALT and ERR signals >>

#### 3.1.5 Integrating the new module into software

To use the new system component, it must be declared within the storm soc basic.h file.

<< Register address declaration >>

Now you can access the device within your program:

<< Changing the duty cycle of PWM channel 0 to '8' >>

#### 3.2 Changing Memory Size

If your FPGA does not provide enough dedicated memory elements to create a 32kb SRAM or if you simply do not need this amount of storage capability, you can reduce the size of the internal memory. Of course you can also extend the memory size (for example when using external memory).

Changing the memory size in the top entity's address map (the memory size must be entered in bytes):

```
constant INT_MEM_BASE_C : STD_LOGIC_VECTOR(31 downto 0) := x"000000000";
constant INT_MEM_SIZE_C : natural := 32*1024; -- byte
constant BOOT_ROM_BASE_C : STD_LOGIC_VECTOR(31 downto 0) := x"FFF00000";
constant BOOT_ROM_SIZE_C : natural := 8*1024; -- byte
...
```

<< Memory size configuration (blue → internal SRAM) >>

Open the STORMcore-ROM.ld linker file in the "build" of your program folder. Change the RAM length corresponding to the new memory size and set the STACK\_SIZE to a value covering your requirements (like ½ memory\_size).

```
ENTRY(_boot)
STACK_SIZE = 0x4000;

/* Memory Definitions */
MEMORY
{
   ROM (rx) : ORIGIN = 0xFFF00000, LENGTH = 0x00002000
   RAM (rw) : ORIGIN = 0x00000000, LENGTH = 0x00008000
}
```

<< "STORMcore-RAM.ld" stack and memory size definition >>

If you have changed any memory size (RAM or ROM), you have to modify the memory definitions of the bootloader code, too. Afterwards, you need to recompile it and load the new image into the memory initialization area of the BOOT\_ROM.vhd component.

Currently, only a bootloader version using 8\*1024 bytes ROM and 32\*1024 bytes RAM is impemented. Bootloader images supporting other SRAM sizes will be selectable via the boot ROM initialization string will be implemented in future versions.

#### 3.3 Software Setup

The STORM SoC project features WinARM\* compatible makefiles, which allow fast and easy program setup. These files also include a STORM Core specific start-up code, which takes care of a proper system initialization.

\*) Download and installation tutorial for WinARM: <a href="http://www.winarm.scienceprog.com/comment/2">http://www.winarm.scienceprog.com/comment/2</a>

Include the STORMcore.h (processor internal definitions) and the STORMsoc.h (module address map) within the application program, to get easy access to processor/system functions.

To guarantee a fast and easy program setup, an IO driver file is included. Via this file, programmers can easily use all system modules. Most of the control functions feature a short information text, so no further function explanation should be necessary.

The "io\_driver.c" / "io\_driver.h" enables easy access to the following hardware components:

- General purpose IO controller 0 (read/write port/pin, toggle pin)
- PWM controller 0 (read/write PWM channel duty cycle)
- GP miniUART 0 (receive/send byte)
- SPI controller 0 (config SPI, read&write SPI, manual (de-)select devide)
- I<sup>2</sup>C controller 0 (config I<sup>2</sup>C, read/write to/from I<sup>2</sup>C device)
- System (access to system coprocessor & CMSR)

Open the system console (execute CMD.exe) and navigate to the software folder of the STORM SoC project folder. Enter and execute "make clean all" to compile your project (main file is "main.c").

```
...\storm_soc\trunk\basic_system\software\demo_program> make clean all
```

After the assembler has finished, the storm\_extractor will create a "storm\_program.txt" file for direct memory initialization and also a "storm\_program.bin" file, which can be downloaded into the STORM Core's RAM or an attached I<sup>2</sup>C EEPROM via the pre-installed STORM SoC bootloader.

The "demo\_program" folder contain a simple demo program, which blinks LED(0) of the system IO port and echoes any received (UART) character to the terminal program.

See the next chapter to see how you can download the demo program into the STORM SoC's SRAM.

#### 3.4 Using the Bootloader

The boot ROM component of the STORM SoC is pre-loaded with a powerful bootloader software. Connect the serial port of the STORM SoC (RXD and TXD) via an RS232 transceiver to your host PC and launch a terminal program (like Hterm.exe from the tools folder). Configure the terminal program corresponding to the default system configuration (baud rate = 9600, 8 data bits, 1 stop bit, no parity bits). Press the reset button of the STORM SoC. Now, the bootloader menu should appear in the terminal window (see below).

<< bootloader console output >>

To download a program to the STORM SoC, press (and transmit) '1'. Afterwards, you can send ("Send File") the "storm\_program.bin" programming file, which was created by the makefile / the storm\_extractor, respectively (in byte-stream mode = no handshake, no transmission frames, simple raw data).

You can also download this programming file into an attached I<sup>2</sup>C EEPROM (like 24FC64 - the device must be accessible with a 16-bit address). After programming, you can configure the STORM SoC via the boot configuration port to boot automatically from the EEPROM after power-up. Press (and transmit) 'a' / 'h' within the bootloader console to get more information.

It is also possible to copy the content of the "storm\_program.txt" file to the memory initialization area inside the MEMORY.vhd component. Then it is possible to boot from the internal RAM, directly.

#### 4. System Components

This chapter gives a brief overview of all components, which are already included in the STORM SoC's source files. These components allow you to create a basic system on chip without downloading (and eventually porting) other IP cores.

Of course it is possible to expand the module library with other (Wishbone) compatible components.

#### **Notes**

- Most of the components, which are connected to the Wishbone bus, can be byte-accessed, even if this feature is not relevant within the STORM SoC (due to the static 32-bit interface=.
- All modules are Wishbone compatible and use therefore the same signal namings for the bus interface. These bus interface signals are not listed in the component's description, only special (non-Wishbone) signals are mentioned.
- Most components, which where not created by me, feature an additional data sheet. See the component's doc folder.
- IO devices are automatically protected and can only be accessed in privileged modes.
- Due to the fabric-internal address-comparator and -mappings, the register order of the relative memory address map is not always equal to the register order in the system memory map. Use only the addresses / IO locations specified in the system memory map.

#### **4.1 STORM Core Processor**

Author: Stephan Nolting

File name of component's top entity: STORM TOP.vhd

The STORM Core Processor is the heart of the STORM SoC. It's sources are not included within the SoC project and must be downloaded separately at: <a href="http://www.opencores.com/project,storm\_core">http://www.opencores.com/project,storm\_core</a>.

All IO/Memory transactions are controlled by the STORM Core and only by the STORM Core – there is no DMA implemented. It is equipped with separated, full-associative cache units for instructions and data. A Wishbone compatible bus unit connects these units to rest of the system.

The core itself is compatible to ARM's famous RISC controller family ( $\rightarrow$  ARMv2 Instruction Architecture). The opcodes, the functionality as well as the programmer's model are ARM-native.



See the STORM Core data sheet in the core's doc folder for more information.

#### **Configuration**

| Generic           | Generic type           | Function                                |
|-------------------|------------------------|-----------------------------------------|
| I_CACHE_PAGES     | natural                | Number of pages in I-Cache              |
| I_CACHE_PAGE_SIZE | natural                | I-Cache page size (# of 32-bit words)   |
| D_CACHE_PAGES     | natural                | Number of pages in D-Cache              |
| D_CACHE_PAGE_SIZE | natural                | D-Cache page size (# of 32-bit words)   |
| TIME_OUT_VAL      | natural                | Maximum Wishbone bus cycle length       |
| BOOT_VECTOR       | std_logic_vector(31:0) | Boot vector address                     |
| IO_UC_BEGIN       | std_logic_vector(31:0) | First address of not cache-able IO area |
| IO_UC_END         | std_logic_vector(31:0) | Last address of not cache-able IO are   |

# **Interface**

| Port signal | Signal size | Direction | Function                                                                                                                                                                                                                    |
|-------------|-------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_CLK_I  | 1 bit       | Input     | Core clock signal, triggering on rising edge                                                                                                                                                                                |
| RST_I       | 1 bit       | Input     | System rest, high-active, sync to rising edge of core clock                                                                                                                                                                 |
| IO_PORT_O   | 16 bit      | Output    | Direct system output port                                                                                                                                                                                                   |
| IO_PORT_I   | 16 bit      | Input     | Direct system input port                                                                                                                                                                                                    |
| WB_ADR_O    | 32 bit      | Output    | Wishbone bus address, word-boundary → bits(1:0) = "00"                                                                                                                                                                      |
| WB_CTI_O    | 3 bit       | Output    | Wishbone bus cycle type "000" → classic cycle "001" → constant address burst "010" → incrementing address burst "111" → burst end                                                                                           |
| WB_TGD_O    | 7 bit       | Output    | Wishbone bus cycle tag  WB_TGD_O(6) $\rightarrow$ '1' for instruction- / '0' for data transfer  WB_TGD_O(5) $\rightarrow$ '1' for IO- / '0' for MEM access  WB_TGD_O(4:0) $\rightarrow$ STORM Core current status mode code |
| WB_SEL_O    | 4 bit       | Output    | Wishbone bus byte select, always "1111"                                                                                                                                                                                     |
| WB_WE_O     | 1 bit       | Output    | Wishbone bus write enable                                                                                                                                                                                                   |
| WB_DATA_O   | 32 bit      | Output    | Wishbone bus data output                                                                                                                                                                                                    |
| WB_DATA_I   | 32 bit      | Input     | Wishbone bus data input                                                                                                                                                                                                     |
| WB_STB_O    | 1 bit       | Output    | Wishbone bus valid transfer                                                                                                                                                                                                 |
| WB_CYC_O    | 1 bit       | Output    | Wishbone bus valid cycle                                                                                                                                                                                                    |
| WB_ACK_I    | 1 bit       | Input     | Wishbone bus acknowledge signal                                                                                                                                                                                             |
| WB_ERR_I    | 1 bit       | Input     | Wishbone bus abnormal cycle termination                                                                                                                                                                                     |
| WB_HALT_I   | 1 bit       | Input     | Wishbone bus halt                                                                                                                                                                                                           |
| IRQ_I       | 1 bit       | Input     | Interrupt request                                                                                                                                                                                                           |
| FIQ_I       | 1 bit       | Input     | Fast interrupt request                                                                                                                                                                                                      |

#### 4.2 Internal SRAM

Author: Stephan Nolting

File name of component's top entity: MEMORY.vhd

This memory component is the basic module for the internal data/program memory. Set the OUTPUT\_GATE generic "true", if you are using an or-based Wishbone data read-back. Enabling this feature might cause problems for the synthesis tool to map the memory to dedicated memory components.

The memory can be initialized with a program code or data segment when needed. Place the program/data in the "INIT MEMORY IMAGE" labeled signal initialization (this feature should only be used for simulation / debugging).

## **Interface / Configuration**

| Generic       | Generic type | Function                               |
|---------------|--------------|----------------------------------------|
| MEM_SIZE      | natural      | Memory size in cells (=32 bit entries) |
| LOG2_MEM_SIZE | natural      | Log2 of memory size (= log2(MEM_SIZE)) |
| OUTPUT_GATE   | boolean      | Use and-gates for data output          |

| Relative address | Area (byte) | R/W | Function                                    |
|------------------|-------------|-----|---------------------------------------------|
| 0x0000000        | MEM_SIZE*4  | R/W | Free-to-use memory cells, each 4 bytes wide |
| MEM_SIZE-4       |             |     |                                             |

#### 4.3 Boot ROM

Author: Stephan Nolting

File name of component's top entity: BOOT ROM FILE.vhd

This memory component is the basic module for the internal boot rom memory. Set the OUTPUT\_GATE generic "true", if you are using an or-based Wishbone data read-back. Enabling this feature might cause problems for the synthesis tool to map the memory to dedicated memory components.

The memory can be initialized with a program code or data segment when needed, pre-installed bootloaders for several development boards can be selected via the INIT\_IMAGE\_ID. Ensure, the STORM Core is booting up from the base address of the boot ROM.

#### **Interface / Configuration**

| Generic       | Generic type | Function                               |
|---------------|--------------|----------------------------------------|
| MEM_SIZE      | natural      | Memory size in cells (=32 bit entries) |
| LOG2_MEM_SIZE | natural      | Log2 of memory size (= log2(MEM_SIZE)) |
| OUTPUT_GATE   | boolean      | Use and-gates for data output          |
| INIT_IMAGE_ID | string       | Name of initialization image           |

| Relative address | R/W | Function                                    |
|------------------|-----|---------------------------------------------|
| 0x0000000        | R   | Free-to-use memory cells, each 4 bytes wide |
| MEM_SIZE-4       |     |                                             |

#### **4.4 IO Controller**

Author: Stephan Nolting

File name of component's top entity: GP\_IO\_CTRL.vhd

The IO controller provides a simple IO port. 32 bits are used as outputs, another 32 are used as inputs. It can be used for directly controlling FPGA pins or for internal system control functions. The IRQ output will go high for one clock cycle when the status of the inputs has changed.

Do not leave any input pin floating. This might cause unintended IRQ generation.

## **Interface / Configuration**

| Special signal | Signal type            | Function                      |
|----------------|------------------------|-------------------------------|
| GP_IO_O        | std_logic_vector(31:0) | Parallel output port          |
| GP_IO_I        | std_logic_vector(31:0) | Parallel input                |
| IO_IRQ_O       | std_logic              | Input status change interrupt |

| Relat | tive address | R/W | Function             |
|-------|--------------|-----|----------------------|
| 0x0   | 0000000      | R/W | Output port register |
| 0x0   | 0000004      | R/W | Input port register  |

## 4.5 Seven Segment Controller

Author: Stephan Nolting

File name of component's top entity: SEVEN\_SEG\_CTRL.vhd

Up to four (d = 0..3) high or low-active seven segment display can be controlled with this module. To display hexadecimal numbers, the corresponding value can be written to the DATA register (offset = 0). To display other symbols, you can write to the CTRL register (offset = 4) to directly control the display segments. Hex-coded DATA will be decoded and the decoded value is automatically written to the CTRL register.

## Display control lines (d is the led-display index):

```
A-segment(d) <= HEX_O(d+0)
B-segment(d) <= HEX_O(d+1)
C-segment(d) <= HEX_O(d+2)
D-segment(d) <= HEX_O(d+3)
E-segment(d) <= HEX_O(d+4)
F-segment(d) <= HEX_O(d+5)
G-segment(d) <= HEX_O(d+6)
```

#### **Display segments:**

```
AAAAA
F B
F B
GGGGG
E C
E C
DDDDDD
```

```
display(d) <= DATA_REGISTER(d*4+3 downto d*4+0) display(d) <= CTRL_REGISTER(d*7+6 downto d*7+0) display(d) <= HEX O(d*7+6 downto d*7+0)
```

#### **Interface / Configuration**

| Generic            | Generic type | Function                       |
|--------------------|--------------|--------------------------------|
| HIGH_ACTIVE_OUTPUT | boolean      | Connected LEDs are high-active |

| Special signal | Signal type            | Function                                     |
|----------------|------------------------|----------------------------------------------|
| HEX_O          | std_logic_vector(27:0) | Control signals for 4 seven segment displays |

| Relative address | R/W | Function              |
|------------------|-----|-----------------------|
| 0x0000000        | R/W | Hex DATA register     |
| 0x0000004        | R/W | Segment CTRL register |

#### **4.6 Timer**

Author: Stephan Nolting

File name of component's top entity: TIMER.vhd

This timer can be used for any timing application. Whenever the counter register value reaches the threshold value, an interrupt (when enabled) is generated. An automatic reset can e applied if bit 1 of the control register is set. A prescaler value different from 0 will scale the frequency of the counter increment. The interrupt output signal will become high for one clock cycle, when the counter register value reached the threshold value (and interrupt enable bit is set).

## **Interface / Configuration**

| Special signal | Signal type | Function                                |
|----------------|-------------|-----------------------------------------|
| INT_O          | std_logic   | Compare interrupt, one clock cycle high |

## Relative address map

| Relative address | R/W | Function                 |
|------------------|-----|--------------------------|
| 0x0000000        | R/W | Counter register         |
| 0x0000004        | R/W | Threshold value register |
| 0x0000008        | R/W | Configuration register   |
| 0x000000C        | R/W | Scratch register         |

#### **Configuration Register**

| Bit(s) | R/W | Function                           |
|--------|-----|------------------------------------|
| 3116   | R/W | Prescaler value                    |
| 153    | R/W | unused                             |
| 2      | R/W | Interrupt enable                   |
| 1      | R/W | Auto reset after threshold reached |
| 0      | R/W | Timer enable                       |

## **4.7 Vector Interrupt Controller**

Author: Stephan Nolting

File name of component's top entity: VIC.vhd

The vectorized interrupt controller is mostly compatible to the one used e.g. in LPC ARM controller. Up to 16 interrupt sources can be configured using vectorized interrupt service routine (ISR) addresses. Another 16 interrupt request lines can be mapped to one interrupt service routine. See the data sheet of an LPC ARM controller for more information about the VIC.

| Relative address | R/W | Function                                                                        |
|------------------|-----|---------------------------------------------------------------------------------|
| 0x0000000        | R   | Masked IRQ request status                                                       |
| 0x0000004        | R   | Masked FIQ request status                                                       |
| 0x0000008        | R   | Unmasked interrupt requests                                                     |
| 0x000000C        | R/W | Interrupt lines type select, '0' = IRQ, '1' = FIQ                               |
| 0x0000010        | R/W | Interrupt request lines enable                                                  |
| 0x0000014        | M   | Clear interrupt request line enable                                             |
| 0x0000018        | W   | Trigger interrupt request line by software                                      |
| 0x000001C        | M   | Clear software interrupt request line                                           |
| 0x00000020       | R/W | Bit 0: Protected mode enable → access only in privileged modes possible         |
| 0x0000030        | R/W | Interrupt service routine address / interrupt acknowledge                       |
| 0x00000034       | R/W | Interrupt service routine address for unvectorized interupts                    |
| 0x00000038       | R/W | High level / rising edge ('0') or low level / falling edge trigger              |
| 0x000003C        | R/W | Level triggered ('0') or edge triggered ('1') interrupt                         |
| 0x0000040        | R/W | Interrupt service routine address for corresponding interrupt channel           |
| 0x000007C        |     |                                                                                 |
| 0x0000080        | R/W | Source select (bits 4:0) and enable (bit 5) for corresponding interrupt channel |
| 0x000000BC       |     |                                                                                 |

#### 4.8 Mini UART

Author: Philippe Carton (opencores) Modified by: Stephan Nolting

File name of component's top entity: MINI\_UART.vhd

This is a simple UART, created by Philippe Carton. It is capable of transmitting, receiving data via the RS232 port. The system was modified to support 32-bit Wishbone bus access.

## **Interface / Configuration**

| Special signal | Signal type | Function                      |
|----------------|-------------|-------------------------------|
| IntTx_O        | std_logic   | Waiting for byte interrupt    |
| IntRx_O        | std_logic   | Byte received interrupt       |
| BR_CLK_I       | std_logic   | Clock used for baud generator |
| TxD_PAD_O      | std_logic   | Transmitter output            |
| RxD_PAD_I      | std_logic   | Receiver input                |

## Relative address map

| Relative address | R/W | Function                                                        |
|------------------|-----|-----------------------------------------------------------------|
| 0x0000000        | R/W | UART data register Bits [7:0]: Received / transmitted character |
|                  |     | Bits [7.0]. Received 7 transmitted character                    |
| 0x0000004        | R/W | UART status register                                            |
|                  |     | Bit 0: Ready to send when '1'                                   |
|                  |     | Bit 1: Byte received when '1'                                   |
|                  |     | Bit 3116: BAUD rate divisor = clk_freq/(4*baud_rate);           |

## **Configuration Register**

| Bit(s) | R/W | Function                                                            |
|--------|-----|---------------------------------------------------------------------|
| 0      | R   | Ready to send when '1'                                              |
| 1      | R   | Byte received when '1', auto-cleared when reading the data register |
| 3116   | R/W | Baud rate divisor = clk_freq/(4*baud_rate);                         |

## 4.9 SPI Controller

Author: Simon Srot (opencores)

File name of component's top entity: spi\_top.v

This SPI controller provides a high-speed SPI port with 8 low-active slave select signals.

## Relative address map

| Relative address | R/W | Function                           |  |
|------------------|-----|------------------------------------|--|
| 0x0000000        | R/W | Data receive / transmit register 0 |  |
| 0x0000004        | R/W | Data receive / transmit register 1 |  |
| 0x00000008       | R/W | Data receive / transmit register 2 |  |
| 0x000000C        | R/W | Data receive / transmit register 3 |  |
| 0x0000010        | R/W | Control and status register        |  |
| 0x0000014        | R/W | Clock divider register             |  |
| 0x0000018        | R/W | Slave select register              |  |



See the data sheet in the component's doc folder for more information.

#### 4.10 I<sup>2</sup>C Controller

Author: Richard Herveille (opencores)

File name of component's top entity: i2c master top.vhd

The I2C controller implements an interface for on-board communication via I<sup>2</sup>C.

This device was originally created for an eight bit bus system, so only the lowest 8 bits of the data bus are relevant, all other bits are read as zero. Writing data on bits 31 downto 8 does not perform any operation.

#### Relative address map

| Relative address | R/W | Function                          |  |
|------------------|-----|-----------------------------------|--|
| 0x0000000        | R/W | Clock divider register, low byte  |  |
| 0x0000004        | R/W | Clock divider register, high byte |  |
| 0x0000008        | R/W | Control register                  |  |
| 0x000000C        | R/W | Receive / transmit data register  |  |
| 0x0000010        | R/W | Command / status register         |  |



See the data sheet in the component's doc folder for more information.

#### 4.11 PS-2 Keyboard Controller

Author: Daniel Quinter (opencores)

File name of component's top entity: ps2 wb.vhd

Via this controller, a ps-2 compatible keyboard can be connected to the STORM SoC.

#### Relative address map

| Relative address | R/W | Function                         |  |  |
|------------------|-----|----------------------------------|--|--|
| 0x0000000        | R/W | Receive / transmit data register |  |  |
| 0x0000004        | R/W | Status / control register        |  |  |

## **4.12 External Memory Controller**

# >> Currently not implemented <<

No external memory controller is currently supported by the STORM SoC. Maybe you can implement one ;)

#### 4.13 Reset Protector

Author: Stephan Nolting

File name of component's top entity: RST\_PROTECT.vhd

The reset protector is not connected to the Wishbone bus system. It is responsible for generating a valid system reset from an external reset request. Only when a valid external reset is applied to the <code>EXT\_RST\_I</code> input for at least <code>TRIGGER\_VAL</code> clock cycles, the <code>SYS\_RST\_O</code> pin is taken high for <code>TRIGGER\_VAL/10000</code> cycles.

#### **Interface / Configuration**

| Generic     | Generic type | Function                                   |  |
|-------------|--------------|--------------------------------------------|--|
| TRIGGER_VAL | natural      | Trigger value in clock ticks               |  |
| LOW_ACT_RST | booelan      | EXT_RST_I is low active when set to "true" |  |

| Special signal | Signal type | Function                  |
|----------------|-------------|---------------------------|
| MAIN_CLK_I     | std_logic   | System clock              |
| EXT_RST_I      | std_logic   | External reset request    |
| SYS_RST_O      | std_logic   | System reset, high active |

## 4.14 System PLL

Author: Altera Quartus II - Megawizzard

File name of component's top entity: SYSTEM\_PLL.vhd

This component was generated by the Altera Megawizzard tool. The phase locked loop is used to create the internal and external clock signals, as well as a system reset (only active during warm-up of PLL).

#### Interface

| Special signal | Signal type | Function                          |  |
|----------------|-------------|-----------------------------------|--|
| inclk0         | std_logic   | External clock input              |  |
| c0             | std_logic   | System clock                      |  |
| c1             | std_logic   | Memory clock = system clock / 2   |  |
| c2             | std_logic   | Memory clock, -3ns phase shifted  |  |
| locked         | std_logic   | Clock outputs are stable when '1' |  |

#### 4.15 PWM Controller

Author: Stephan Nolting

File name of component's top entity: PWM\_CTRL.vhd

This controller provides 8 output ports, which can be configured with a specific on/off pulse-width. The controller can be used to add 'analog' outputs to the design.

The operating frequency of a PWM channel is WB CLK/64.

The duty cycle of a single port can be set by an 8-bit value (duty\_cycle = value/255).

Setting the duty\_cycle bits of a port to 0xFF (duty\_cycle = 1) will permanently activate the port (high).

Setting the duty\_cycle bits of a port to 0x00 (duty\_cycle = 0) will permanently deactivate the port (low).

#### **Interface**

| Special signal | Signal type           | Function                   |
|----------------|-----------------------|----------------------------|
| PWM_O          | std_logic_vector(7:0) | 8 independent PWM channels |

#### Relative address map

| Relative address | R/W | Function                                           |  |  |  |
|------------------|-----|----------------------------------------------------|--|--|--|
| 0x00000000       | R/W | PWM configuration register 0 (for channel 0,1,2,3) |  |  |  |
| 0x0000004        | R/W | PWM configuration register 1 (for channel 4,5,6,7) |  |  |  |

#### PWM configuration register 0/1

| Bits | R/W | Function               |  |  |
|------|-----|------------------------|--|--|
| 3124 | R/W | Channel 0/4 duty_cylce |  |  |
| 2316 | R/W | Channel 1/5 duty_cylce |  |  |
| 1508 | R/W | Channel 2/6 duty_cylce |  |  |
| 0700 | R/W | Channel 3/7 duty_cylce |  |  |

#### 5. Hardware Source Files

All hardware sources can be found in the component's rtl directory. The top entity of the corresponding component is listed first and is highlighted.

Note: The source files of the STORM Core processor itself are not included in the STORM SoC project. They must be downloaded separately at <a href="http://www.opencores.com/project,storm">http://www.opencores.com/project,storm</a> core

#### STORM Core Processor:

- storm core/trunk/rtl/STORM TOP.vhd
- storm core/trunk/rtl/BUS UNIT.vhd
- storm core/trunk/rtl/CACHE.vhd
- storm core/trunk/rtl/CORE PKG.vhd
- storm core/trunk/rtl/CORE.vhd
- storm core/trunk/rtl/OPCODE DECODER.vhd
- storm core/trunk/rtl/FLOW CTRL.vhd
- storm core/trunk/rtl/MC SYS.vhd
- storm core/trunk/rtl/REG FILE.vhd
- storm core/trunk/rtl/OPERAND UNIT.vhd
- storm core/trunk/rtl/MS UNIT.vhd
- storm core/trunk/rtl/MULTIPLY UNIT.vhd
- storm core/trunk/rtl/BARREL SHIFTER.vhd
- storm core/trunk/rtl/ALU.vhd
- storm core/trunk/rtl/LOAD STORE UNIT.vhd
- storm core/trunk/rtl/WB UNIT.vhd

#### STORM SoC Basic configuration:

- storm soc/trunk/basic system/STORM SoC basic.vhd

#### Boot ROM:

- storm soc/trunk/components/boot rom/rtl/BOOT ROM FILE.vhd

#### I 2C controller:

- storm soc/trunk/components/i2c controller/rtl/vhdl/i2c master top.vhd
- storm\_soc/trunk/components/i2c\_controller/rtl/vhdl/i2c\_master\_byte\_ctrl.vhd
- storm soc/trunk/components/i2c controller/rtl/vhdl/i2c master bit ctrl.vhd

#### IO controller:

- storm soc/trunk/components/io controller/rtl/GP IO CTRL.vhd

#### miniUART:

- storm soc/trunk/components/miniuart/rtl/vhdl/MINI\_UART.vhd
- storm soc/trunk/components/miniuart/rtl/vhdl/rxunit.vhd
- storm\_soc/trunk/components/miniuart/rtl/vhdl/txunit.vhd
- storm\_soc/trunk/components/miniuart/rtl/vhdl/utils.vhd

## by Stephan Nolting

PS-2 controller:

- storm soc/trunk/components/ps2core/rtl/vhdl/ps2 wb.vhd
- storm soc/trunk/components/ps2core/rtl/vhdl/ps2.vhd

#### Reset protector:

- storm soc/trunk/components/reset protector/rtl/RST PROTECT.vhd

#### Seven segment controller:

- storm soc/trunk/components/seven segment controller/rtl/SEVEN\_SEG\_CTRL.vhd

#### SPI controller:

- storm\_soc/trunk/components/spi\_controller/rtl/verilog/spi\_top.v
- storm\_soc/trunk/components/spi\_controller/rtl/verilog/spi\_clgen.v
- storm soc/trunk/components/spi controller/rtl/verilog/spi defines.v
- storm\_soc/trunk/components/spi\_controller/rtl/verilog/spi\_shift.v
- storm soc/trunk/components/spi controller/rtl/verilog/timescale.v

#### SPI controller:

- storm soc/trunk/components/sram memory/rtl/MEMORY.vhd

#### System timer:

- storm soc/trunk/components/timer/rtl/TIMER.vhd

#### Vectorized interrupt controller:

- storm soc/trunk/components/vector interrupt controller/rtl/VIC.vhd

#### Pulse-Width-Modulation controller:

- storm soc/trunk/components/pwm controller/rtl/PWM CTRL.vhd

# 6. System Address Map

# **Memory Address Map (→ cache-access only)**

| Address (hex)                | Name                  | R/W | Module                    | Register           |
|------------------------------|-----------------------|-----|---------------------------|--------------------|
| 0x00000000<br><br>0x00008000 | IRAM_BASE<br>+ offset | R/W | 32 kb internal<br>SRAM    | 32-bit memory cell |
| 0xFFF00000<br><br>0xFFF00800 | ROM_BASE<br>+ offset  | R   | 8 kb internal boot<br>ROM | 32-bit memory cell |

# IO Address Map (→ dedicated IO-access only)

| Address (hex) | Name          | R/W | Module                        | Register                  |
|---------------|---------------|-----|-------------------------------|---------------------------|
| 0xFFFF0000    | GPIO0_OUT     | R/W | General purpose               | 32 bit output port        |
| 0xFFFF0004    | GPIO0_IN      | R   | IO controller 0               | 32 bit input port         |
| 0xFFFF0018    | UARTO_DATA    | R/W | miniUART 0                    | RX/TX data register       |
| 0xFFFF001C    | UARTO_SREG    | R/W |                               | Status register           |
| 0xFFFF0020    | STME0_CNT     | R/W | System timer 0                | Counter register          |
| 0xFFFF0024    | STME0_VAL     | R/W |                               | Threshold value           |
| 0xFFFF0028    | STME0_CONF    | R/W |                               | Configuration register    |
| 0xFFFF002C    | STME0_SCRT    | R/W |                               | Scratch register          |
| 0xFFFF0030    | SPIO_CONF     | R/W | SPI controller 0              | Configuration register    |
| 0xFFFF0034    | SPIO_PRSC     | R/W |                               | Prescaler value           |
| 0xFFFF0038    | SPI0_SCSR     | R/W |                               | Slave select register     |
| 0xFFFF0040    | SPIO_DATO     | R/W |                               | FIFO data register 0      |
| 0xFFFF0044    | SPIO_DAT1     | R/W |                               | FIFO data register 0      |
| 0xFFFF0048    | SPIO_DAT2     | R/W |                               | FIFO data register 0      |
| 0xFFFF004C    | SPIO_DAT3     | R/W |                               | FIFO data register 0      |
| 0xFFFF0050    | I2CO_CMD/STAT | R/W | I <sup>2</sup> C controller 0 | Command / status register |
| 0xFFFF0060    | I2CO_PRLO     | R/W |                               | Prescaler, low byte       |
| 0xFFFF0064    | I2CO_PFHI     | R/W |                               | Prescaler, high byte      |
| 0xFFFF0068    | I2CO_CTRL     | R/W |                               | Control register          |
| 0xFFFF006C    | I2CO_DATA     | R/W |                               | RX/TX data register       |

| Address (hex) | Name                              | R/W | Module           | Register                            |  |  |  |
|---------------|-----------------------------------|-----|------------------|-------------------------------------|--|--|--|
| 0xffff0070    | PWM0_CONFIG_0                     | R/W | PWM Controller 0 | PWM channel 0,1,2,3 configuration   |  |  |  |
| 0xFFFF0074    | PWM0_CONFIG_1                     | R/W |                  | PWM channel 4,5,6,7 configuration   |  |  |  |
|               | << add additional modules here >> |     |                  |                                     |  |  |  |
| 0xfffff000    | VICIRQStatus                      | R   | Vector interrupt | IRQ status (masked)                 |  |  |  |
| 0xfffff004    | VICFIQStatus                      | R   | controller       | FIQ status (masked)                 |  |  |  |
| 0xFFFFF008    | VICRawIntr                        | R   |                  | Unmasked interrupt request status   |  |  |  |
| 0xfffff00C    | VICIntSelect                      | R/W |                  | Interrupt type, '1' FIQ, '0' IRQ    |  |  |  |
| 0xFFFFF010    | VICIntEnable                      | R/W |                  | INT request lines enable            |  |  |  |
| 0xFFFFF014    | VICIntEnClear                     | W   |                  | Clear INT request line enable bit   |  |  |  |
| 0xFFFFF018    | VICSoftInt                        | W   |                  | Trigger INT line by software        |  |  |  |
| 0xFFFFF01C    | VICSoftintClear                   | W   |                  | Clear SW INT request enable bit     |  |  |  |
| 0xfffff020    | VICProtection                     | R/W |                  | Protected mode (only priv. acc.)    |  |  |  |
| 0xfffff030    | VICVectAddr                       | R/W |                  | ISR address / INT acknowledge       |  |  |  |
| 0xfffff034    | VICDefVectAddr                    | R/W |                  | ISR address for non-vectorized INTs |  |  |  |
| 0xFFFFF038    | VICTrigLevel                      | R/W |                  | Hi/Lo / rising/falling edge detect  |  |  |  |
| 0xfffff03C    | VICTrigMode                       | R/W |                  | Level/edge INT detector             |  |  |  |
| 0xfffff040    | VICVectAddr0                      | R/W |                  | ISR address for VEC_INT 0           |  |  |  |
| 0xFFFFF044    | VICVectAddr1                      | R/W |                  | ISR address for VEC_INT 1           |  |  |  |
| 0xFFFFF048    | VICVectAddr2                      | R/W |                  | ISR address for VEC_INT 2           |  |  |  |
| 0xFFFFF04C    | VICVectAddr3                      | R/W |                  | ISR address for VEC_INT 3           |  |  |  |
| 0xfffff050    | VICVectAddr4                      | R/W |                  | ISR address for VEC_INT 4           |  |  |  |
| 0xFFFFF054    | VICVectAddr5                      | R/W |                  | ISR address for VEC_INT 5           |  |  |  |
| 0xFFFFF058    | VICVectAddr6                      | R/W |                  | ISR address for VEC_INT 6           |  |  |  |
| 0xFFFFF05C    | VICVectAddr7                      | R/W |                  | ISR address for VEC_INT 7           |  |  |  |
| 0xfffff060    | VICVectAddr8                      | R/W |                  | ISR address for VEC_INT 8           |  |  |  |
| 0xfffff064    | VICVectAddr9                      | R/W |                  | ISR address for VEC_INT 9           |  |  |  |
| 0xFFFFF068    | VICVectAddr10                     | R/W |                  | ISR address for VEC_INT 10          |  |  |  |
| 0xFFFFF06C    | VICVectAddr11                     | R/W |                  | ISR address for VEC_INT 11          |  |  |  |
| 0xFFFFF070    | VICVectAddr12                     | R/W |                  | ISR address for VEC_INT 12          |  |  |  |
| 0xFFFFF074    | VICVectAddr13                     | R/W |                  | ISR address for VEC_INT 13          |  |  |  |
| 0xFFFFF078    | VICVectAddr14                     | R/W |                  | ISR address for VEC_INT 14          |  |  |  |
| 0xFFFFF07C    | VICVectAddr15                     | R/W |                  | ISR address for VEC_INT 15          |  |  |  |
| 0xFFFFF080    | VICVectCntl0                      | R/W |                  | Source select / Enable VEC_INT 0    |  |  |  |

| Address (hex) | Name          | R/W | Module           | Register                          |
|---------------|---------------|-----|------------------|-----------------------------------|
| 0xFFFFF084    | VICVectCntl1  | R/W | Vector interrupt | Source select / Enable VEC_INT 1  |
| 0xFFFFF088    | VICVectCntl2  | R/W | controller       | Source select / Enable VEC_INT 2  |
| 0xFFFFF08C    | VICVectCntl3  | R/W |                  | Source select / Enable VEC_INT 3  |
| 0xFFFFF090    | VICVectCntl4  | R/W |                  | Source select / Enable VEC_INT 4  |
| 0xFFFFF094    | VICVectCntl5  | R/W |                  | Source select / Enable VEC_INT 5  |
| 0xFFFFF098    | VICVectCntl6  | R/W |                  | Source select / Enable VEC_INT 6  |
| 0xFFFFF09C    | VICVectCntl7  | R/W |                  | Source select / Enable VEC_INT 7  |
| 0xFFFFF0A0    | VICVectCntl8  | R/W |                  | Source select / Enable VEC_INT 8  |
| 0xFFFFF0A4    | VICVectCntl9  | R/W |                  | Source select / Enable VEC_INT 9  |
| 0xFFFFF0A8    | VICVectCntl10 | R/W |                  | Source select / Enable VEC_INT 10 |
| 0xFFFFF0AC    | VICVectCntl11 | R/W |                  | Source select / Enable VEC_INT 11 |
| 0xFFFFF0B0    | VICVectCntl12 | R/W |                  | Source select / Enable VEC_INT 12 |
| 0xFFFFF0B4    | VICVectCntl13 | R/W |                  | Source select / Enable VEC_INT 13 |
| 0xFFFFF0B8    | VICVectCntl14 | R/W |                  | Source select / Enable VEC_INT 14 |
| 0xfffff0BC    | VICVectCntl15 | R/W |                  | Source select / Enable VEC_INT 15 |

## 7. Interrupt Channels

The vector interrupt controller (VIC) of the STORM SoC supports up to 16 vectorized and another 16 unvectorized interrupt sources. Only vectorized are used for the basic system configuration.

| Channel | Device / Function                     |
|---------|---------------------------------------|
| 0       | System timer 0 threshold reached      |
| 1       | GP IO controller 0 input state change |
| 2       | miniUART 0 TX done                    |
| 3       | miniUART 0 RX done                    |
| 4       | SPI controller 0 IRQ                  |
| 5       | I <sup>2</sup> C controller 0 IRQ     |
| 631     | Unused - enabled                      |